<?php

use think\migration\Migrator;
use think\migration\db\Column;

class Users extends Migrator
{
    /**
     * Change Method.
     *
     * Write your reversible migrations using this method.
     *
     * More information on writing migrations is available here:
     * http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
     *
     * The following commands can be used in this method and Phinx will
     * automatically reverse them when rolling back:
     *
     *    createTable
     *    renameTable
     *    addColumn
     *    renameColumn
     *    addIndex
     *    addForeignKey
     *
     * Remember to call "create()" or "update()" and NOT "save()" when working
     * with the Table class.
     */
    public function change()
    {
        // create the table
        $table = $this->table('users');
        $table->addColumn('username', 'string', ['limit' => 15,'default'=>'','comment'=>'用户名，登陆使用'])
            ->addColumn('email', 'string', ['limit' => 50, 'comment'=>'用户邮箱'])
            ->addColumn('password', 'string', ['limit' => 32, 'comment'=>'用户密码'])
            ->addColumn('salt', 'string', ['limit' => 32, 'comment'=>'加密盐'])
            ->addColumn('role_id', 'integer', ['limit' => 2, 'comment'=>'角色ID'])
            ->addColumn('login_status', 'boolean', ['limit' => 1,'default'=>0,'comment'=>'登陆状态,1已登录'])
            ->addColumn('login_code', 'string', ['limit' => 32,'default'=>0,'comment'=>'排他性登陆标识'])
            ->addColumn('last_login_ip', 'string', ['limit' => 15,'default'=>0,'comment'=>'最后登录IP'])
            ->addColumn('last_login_time', 'datetime', ['comment'=>'最后登录时间'])
            ->addColumn('create_time', 'datetime', ['comment'=>'创建时间'])
            ->addColumn('update_time', 'datetime', ['comment'=>'更新时间'])
            ->addColumn('delete_time', 'datetime', ['comment'=>'软删除'])
            ->addIndex(['username', 'email'], ['unique' => true])
            ->create();
    }
}
